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CODE GENERATOR SYSTEM FOR DIGITAL LIBRARIES 



BACKGROUND OF THE INVENTION 

1. Field of the Invention 

This invention relates in general to computer-implemented database management 
5 systems, and, in particular, to creating a custom digital library using a system description to 
describe data in the digital library and a code generator to generate programs which store and 
locate data in the digital library based on the system specification. 

2, Description of Related Art 

For nearly half a century computers have been used by businesses to manage information 

1 0 such as numbers and text, mainly in the form of coded data. However, business data represents 
only a small part of the world's information. As storage, communication and information 
processing technologies advance, and as their costs come down, it becomes more feasible to 
digitize other various types of data, store large volumes of it, and be able to distribute it on 
demand to users at their place of business or home. 

1 5 New digitization technologies have emerged in the last decade to digitize images, audio, 

and video, giving birth to a new type of digital multimedia information. These multimedia 
objects are quite different from the business data that computers managed in the past, and often 
require more advanced information management system infrastructures with new capabilities. 
Such systems are often called "digital libraries." 

20 Bringing new digital technologies can do much more than just replace physical obj ects 

with their electronic representation. It enables instant access to information; supports fast, 
accurate, and powerful search mechanisms; provides, new "experiential" (i.e. virtual reality) user 
interfaces; and implements new ways of protecting the rights of information owners. These 
properties make digital library solutions even more attractive and acceptable not only to 

25 corporate IS organizations, but to the information owners, publishers and service providers. 

Generally, business data is created by a business process (an airhne ticket reservation, 
a deposit at the bank, and a claim processing at an insurance company are examples). Most of 
these processes have been automated by computers and produce business data in digital form 
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(text and numbers). Therefore it is usually structured coded data. Multimedia data, on the 
contrary, cannot be fully pre-structured (its use is not fully predictable) because it is the result 
of the creation of a human being or the digitization of an object of the real world (x-rays, 
geophysical mapping, etc.) rather than a computer algorithm. 
5 The average size of business data in digital form is relatively small A banking record - 

including a customers name, address, phone number, account number, balance, etc—represents 
at most a few hundred characters, i.e. few hundreds/thousands of bits. The digitization of 
multimedia information (image, audio, video) produces a large set of bits called an "object" or 
"blobs" (Binary Large Objects). For example, a digitized image of the parchments from the 

1 0 Vatican Library takes as much as the equivalent of 30 million characters (30 MB) to be stored. 
The digitization of a movie, even after compression, may take as much as the equivalent of 
several billions of characters (3-4 GB) to be stored. 

Multimedia information is typically stored as much larger objects, ever increasing in 
quantity and therefore requiring special storage mechanisms. Classical business computer 

15 systems have not been designed to directly store such large objects. Specialized storage 
technologies may be required for certain types of information, e.g. media streamers for video or 
music. Because certain multimedia information needs to be preserved "forever" it also requires 
special storage management functions providing automated back-up and migration to new 
storage technologies as they become available and as old technologies become obsolete. 

20 Finally, for performance reasons, the multimedia data is often placed in the proximity of 

the users with the system supporting multiple distributed object servers. This often requires a 
logical separation between apphcations, indices, and data to ensure independence from any 
changes in the location of the data. 

In adigital library (DL), the multimedia object canbe linked with the associated indexing 

25 information, since both are available in digital form. Integration of this legacy catalog 
information with the digitized object is crucial and is one of the great advantages of digital 
library technology. Different types of objects can be categorized differently as appropriate for 
each object type. Existing standards like MARC records for libraries, Finding Aids for archiving 
of special collections, etc. can be used when appropriate. 
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Object-oriented approaches are generally better suited for such complex data 
management. The term "obj ect-oriented" refers to a software design method which uses "classes" 
and "objects" to model abstract or real objects. An "obj ect" is the main building block of obj ect- 
oriented progranuningj and is a programming unit which has both data and functionality (i.e., 
5 "methods"). A "class" defines the implementation of a particular kind of object, the variables 
and methods it uses, and the parent class it belongs to. 

When a customer-specific database is to be built, it is usually necessary to interview the 
customer regarding the content of the database. Then, the objects corresponding to the 
customer's needs are hard coded to build the specified database. Li other words, programming 
1 0 code is generated for each kind of object of the database that was specified by the customer. By 
hard coding objects, the objects are stored in a predefined scheme based on the type of object. 

There are a number of obvious shortcomings with this approach. First, hard coding 
individual databases requires significant time and money. For example, when new objects are 
to be added to the library, new code must be written to represent these objects. Similarly, when 
15 objects are altered or deleted, the database must be altered and reindexed. This process results 
in a very inefficient technique for generating custom databases. These shortcomings are fiirther 
amplified when large, customer specified databases with large objects and/or a large number of 
objects are to be created. Consequently, the conventional, manual technique for hard-coded 
systems is inefficient and is not desirable for databases which may require numerous object 
20 modifications and additions within a digital library. 

Further, other conventional systems which utilize code generators based on static or 
dynamic code generators also have shortcomings. For example, with code generators based on 
embedded static-SQL, code must still be written for each individual object, each added object, 
and each changed object. Further, for each new type of database request, a separate 
25 programming language function must be created. In addition, conventional dynamic embedded- 
SQL code generators do not perform as well as static embedded-SQL code generators and are 
generally directed to small databases rather than larger databases or custom databases. 

Accordingly, there is a need in the art for a system that can create and manage custom 
databases using a search engine that is capable of efficient, run-time storing and locating of data 
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within the database without generating new code, modifying existing code, or reindexing a 
database to reflect the addition, deletion or alteration of an object within a database, 

SUMMARY OF THE INVENTION 
To overcome the hmitations in the prior art described above, and to overcome other 
5 hmitations that will become apparent upon reading and understanding the present 

specification, the present invention discloses a method, apparatus, and article of manufacture 
for creating a custom digital library or database. 

In accordance with the present invention, a system description of a structure of a 
database is received. A structure for the custom database is generated based on the system 
10 description. A search engine based on the system description is generated to store and 
retrieve data in the custom digital library or database. 

BRIEF DESCRIPTION OF THE DRAWINGS 
Referring now to the drawings in which like reference numbers represent corresponding 
parts throughout: 

15 FIG. 1 schematically illustrates the hardware environment of one embodiment of the 

present invention, and more particularly, illustrates a typical database system; 

FIG. 2 schematically illustrates components utihzedby the code generation system in one 
embodiment of the present invention; and 

FIG. 3 is a flow diagram illustrating the order of operation of the technique of the code 
20 generation system in one embodiment of the present invention. 

DETAILED DESCRIPTION 
In the following description of embodiments of the present invention, reference is made 
to the accompanying drawings which form a part hereof, and which are shown by way of 
illustration embodiments in which the invention may be practiced. It is to be understood that 
25 other embodiments may be utilized as structural changes may be made without departing from 
the scope of the present invention. 
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Hardware Environment 
FIG. 1 is a hardware environment used in one embodiment of the invention. The present 
invention is typically implemented using a computer 100, which generally includes, inter alia, 
a processor 102, random access memory (RAM) 104, data storage devices 106 (e.g., hard, 
5 floppy, and/or CD-ROM disk drives, etc.) which may store, for example, digital libraries 107, 
data communications devices 108 (e.g., modems, network interfaces, etc.), display device 110 
(e.g., CRT, LCD display, etc.), input devices 1 12 (e.g., mouse pointing device and keyboard). 
It is envisioned that attached to the computer 1 00 may be other devices, such as read only 
memory (ROM), a video card, bus interface, printers, etc. Those skilled in the art will recognize 

10 that any combination of the above components, or any number of different components, 
peripherals, and other devices, may be used with the computer 100. 

The computer 100 operates under the control of an operating system (OS) 114. The 
operating system 114 is booted into the memory 104 of the computer 100 for execution when 
the computer 100 is powered-on or reset. In turn, the operating system 1 14 then controls the 

15 execution of one or more computer programs 116, such as a storage and retrieval system 118, 
by the computer 100. The present invention is a code generation system 119 and is generally 
implemented in these computer programs 116, which execute under the control of the operating 
system 114 and cause the computer 100 to perform the desired functions as described herein. 
The operating system 114 and computer programs 1 16 are comprised of instructions which, 

20 when read and executed by the computer 1 00, causes the computer 1 00 to perform the steps necessary 
to implement and/or use the code generation system 119. Generally, the operating system 114 and/or 
computer programs 116 are tangibly embodied in and/or readable from a device, carrier, or media, 
such as memory 104, data storage devices 106, and/or data communications devices 108. Under 
control of the operating system 1 14, the computer programs 1 16 may be loaded from the memory 

25 104, data storage devices 106, and/or data communications devices 108 into the memory 104 of the 
computer 100 for use during actual operations. 

Thus, the present invention may be implemented as a method, apparatus, or article of 
manufacture using standard programming and/or engineering techniques to produce software, 
firmware, hardware, or any combination thereof The term "article of manufacture" (or alternatively, 

30 "computerprogram product") asusedhereinis intended to encompass a computer program accessible 
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from any computer-readable device, carrier, or media. Of course, those skilled in the art will 
recognize many modifications may be made to this configuration without departing from the scope 
of the present invention. 

Those skilled in the art will recognize that the environment illusfrated in FIG. 1 is not 
intended to Umit the present invention. Indeed, those skilled in the art will recognize that other 
altemative hardware environments may be used without departing from the scope of the present 
invention. 



XML Summary 

Extensible Markup Language (XML) is a new specification that is quickly gaining 
popularity for creating what are termed "XML documents". XML documents comprise 
structured data. XML documents are being shared between multiple businesses and between 
businesses and customers. With the longstanding use of relational databases, many businesses 
have stored their data in relational tables. Now, however, more businesses are storing data using 
XML documents. 

The code generation system 1 19 utilizes markup files including, for example. Extensible 
Markup Language (XML) documents. XML is a subset of Standard Generahzed Markup 
Language (SGML) which is used for documents with structured information. XML is described 
in XML 1.0, found at the following web site: http://www.w3.org/TR/REC-xml. XML is a set 
of rules or guidelines for designing text formats for structured data using tags. Additional detail 
may be found at the following web site: http://www.w3.org/XML/1999/XML-in-10-points. 
XML is a new specification that is quickly gaining popularity for creating what are termed 
"XML documents" which may be structured by various elements or attiibutes (e.g., title, data, 
author, etc.). Once a document is structured in this manner, a structured search may be 
performed based on element or attribute values (or content). 

XML describes a class of data objects or XML documents and partially describes the 
behavior of computer programs which process them. XML documents are made up of storage 
units called entities. Each entity contains either parsed or unparsed data. Parsed data is made 
up of characters, some of which form the character data in the document. Other parsed data may 
be in the markup form. Markup encodes a description of the document's storage layout and 
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logical structure. XML provides a mechanism to impose constraints on the storage layout and 
logical structure. A software module called an XML processor is used to read XML documents 
and provide access to their content and structure. 

In particular, Extensible Markup Language (XML) is a subset of Standard Generalized 
5 Markup Language (SGML). XML works in conjunction with Extensible Stylesheet Language 
Transformation, (XSLT) and Extensible Markup Language Path ( XPath). XML may also work 
in conjunction with a Document Object Model (DOM) or Namespace. 

Extensible Markup Language (XML) is a subset of Standard Generalized Markup 
Language (SGML). XML is described in XML 1,0, found at the following web site: 
10 http://www.w3.org/TR/REC-xml. Extensible Markup Language (XML) is a set of rules or 
guidelines for designing text formats for structured data using tags. Additional detail may be 
found at the following web site: http://www.w3.org/XML/1999/XML-in-10-points. For 
interoperability, domain-specific tags called a vocabulary can be standardized using aDocument 
Type Definition, so that appUcations in that domain imderstand the meaning of the tags. 
1 5 Extensible Style Language Transformer or XSLT is a language for transforming XML 

documents into other XML documents. The XSLT specification defines the syntax and 
semantics of the XSLT language. XSLT-defined elements are distinguished by belonging to a 
specific XML namespace, which is referred to as the XSLT namespace. A transformation 
expressed in XSLT describes rules for transforming a source tree into a resuU tree. Further detail 
20 about XSLT may be found at http://www.w3 .org/TR/xsh. 

XML Path or XPath addresses parts of an XML document. XPath gets its name from its 
use of a path notation as in URLs for navigating through the hierarchical structure of an XML 
document. Further detail about XML path may be found at http://www.w3.org/TR/xpath. 

A Document Object Model (DOM) is a standard set of function calls for manipulating 
25 XML files from a programming language. Additional detail may be found at the following web 
site: http ://www.w3 .org/TR/REC-DOM-Level- 1 /. 

For example, a sample XML system specification is provided: 
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<?xml encoding-"US-ASCn"?> 

<! -Digital Library schema definitions ~> 



<!ELEMENTDLSystem(DLIndexClass+,DLRelationship*,DLAttribute+,DLPart*)> 

<!~Index class is a list of relationships, attributes, and parts -> 
5 <!ELEMENT DLIndexClass (desc)?> 

<!ATTLIST DLIndexClass 
id ID #REQUIRED 
relationships IDREFS #IMPLIED 
dlattributes IDREFS #REQLfIRED 
1 0 parts IDREFS #IMPLIED> 



<! -Relationships connect index classes ~> 
<!ELEMENT DLRelationship (desc)?> 
<! ATTLIST DLRelationship 
15 id ID #REQUIRED 

type (folder | IDPointer | value) #REQUIRED 
referstoclasses IDREFS #IMPLIED 
fromattribute IDREF #IMPLIED 
toattributes IDREFS #IMPLIED> 



20 <!— attrubutes are data type declarations 

attributes can be in more than one index class ~> 
<!ELEMENT DLAttribute (desc)?> 
<! ATTLIST DLAttribute 
idID#REQUIRED 
25 type (VarChar | FixedChar | Integer | 

Time | Long | TimeStamp | Date | Decimal) #REQUIRED 
length CD ATA #REQUIRED> 



<!-- parts are files or bitstreams -> 
<!ELEMENT DLPart (desc)?> 
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<! ATTLIST DLPart 

id ID #REQUIRED 
partnmnber CD ATA #REQUIRED 
format CDATA #REQUIRED> 
5 <!ELEMENT desc (#PCDATA)> 



CODE GENERATOR SYSTEM FOR DIGITAL LIBRARIES 
One embodiment of the present invention provides a code generation system 1 19. The 
code generation system 119 creates a structure for a custom database and creates one or more 
programs (e.g., a search engine) that store and locate data within the custom database. The 
1 0 programs store and locate data based on a markup file containing a system description of the 
structure of the custom database. 

FIG. 2, a schematic of components utilized by the code generation system 1 19, 
illustrates that a system description 200 of the structure of the custom database to be created 
comprises a markup language fde. The specification may refer to both a "system 
1 5 description" and a "mark-up file," and both of these items refer to the markup file containing 
a system description 200. In one embodiment, the markup language file 200 may be 
constructed using a text editor 210. In an alternative embodiment, the markup language file 
200 may be constructed through graphical user interface (GUI) 220. 

The system description in the markup language file 200 is input into a code generator 
20 230. The code generator 230 reads the markup language file 200, creates objects based on 
the system description, and outputs a structure of a database 240 and one or more programs 
250 (e.g., a search engine program) for storing and retrieving data in the database. In an 
alternative embodiment, the code generation system may output a database structure which 
forms a digital library 107. In an additional embodiment, a digital library 107 may include a 
25 single database. In another embodiment, the digital library 107 may include a collection of 
databases. In addition, a search engine program 260 output by the code generator 240 may 
locate objects or object data in the custom database or digital library 107. 

In an alternative embodiment, the same program may both create the database 
structure 240 and serve as a search engine 250 for that custom database even though FIG. 2 
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illustrates separate programs for the database structure 240 an search engine 250. The 
manner in which these components are utilized by the code generation system 1 19 is 
explained in further detail with reference to FIG. 3. 

FIG. 3 is a flow diagram illustrating the technique of the code generation system 119. 

5 In block 300, the code generator 230 receives markup file containing a system description 
200 of the structure of the custom database to be created. The system description 200 of the 
custom database defines the mapping of the abstract digital asset to the physical 
representation in a database. In other words, the system description 200 defines the structure 
of the custom database to be created through various objects. For example, the system 

1 0 description 200 may include, a set of data that is to be stored in a database, how that data is to 
be stored, how the data is linked or associated with other data, and any other information 
relating to how the data should be stored and/or processed. Those skilled in the art will 
recognize that numerous other object structures and associations may be represented in the 
system description 200. 

1 5 A markup language file stores the system description 200. For example, the system 

description 200 may entered into the markup of an Extensible Markup Language (XML) 
document. In an alternative embodiment of the present invention, the system description 200 
may be entered into a Java document. The system description 200 may be entered into a 
markup file using a text editor 210 or by inputting data through a graphical user interface 

20 (GUI) 220. Those skilled in the art will recognize that the system description may be entered 
using other data entry systems. An example of one embodiment of the present invention 
includes the following XML document with a system description 200: 

<?xmlversion="1.0" ?> 

<!- sample system structure file for a simple video archive~> 
25 - <DLSystem name="libsrvrx" userid="frnadinm" password="password"> 

- <DLIndexClass dlname="VideoAsset"> 
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<!- Attributes are database columns --> 

<DLAttribute id=" VAl " datatype=" VarChar">Video_TapeNum</DLAttribute> 
<DLAttribute id="VA2" datatype="VarChar">Video_ProxyID</DLAttribute> 

<DLAttribute id="VA3" datatype="VarChar">Video_Date</DLAttribute> 

5 <DLAttribute id="VA4" datatype="VarChar">Video_Title</DLAttribute> 

<DLAttribute id="VA5" datatype="VarChar">Video_Type</DLAttribute> 

<DLAttribute id="VA6" datatype="VarChar">Video_IcoiiFile</DLAttribute> 

<DLAttribute id ="VA7" datatype = "VarChar" > Video_NumSBSegments < 
/DLAttribute> 

1 0 <DLAttribute id=" VA8" datatype = "FixedChar" > Video_TCCorrection < 

/DLAttribute> 

<DLAttribute id="VA9" datatype = "FixedChar" defaultvalue = "N" > 
Video_Digitized</DLAttribute> 

<DLAttribute id="VA10" datatype="FixedChar" defaultvalue = "T" > Video_Status 
15 </DLAttribute> 

<DLAttribute id="VAll" datatype="FixedChar" defaultvalue = "N "> 
Video_CheckedOut </DLAttribute> 

<DLAttribute id="VA12" datatype = "VarChar" > Video_COUserName < 
/DLAttribute> 

20 <DLAttribute id="VA13" datatype="Date">Video_CODate</DLAttribute> 

<DLAttribute id="VA14" datatype="Date">Video_CIDate</DLAttribute> 
<DLAttribute id="VA15" datatype="VarChar">Video_ShowNvim</DLAttribute> 
<DLAttribute id=" VAl 6" datatype=" VarChar">Video_LoggerID</DLAttribute> 
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<DLAttribute id="VA17" datatype="FixedChar">Video_LogDate</DLAttribute> 

<DLAttribute id=" VAl 8" datatype=" VarChar ">Video_DigitizerID</DLAttribute> 

<DLAttribute id="VA19" datatype = "FixedChar" > Video DigitizeDate 
</DLAttribute> 

<DLAttribute id ="VA20" datatype="FixedChar">Video_Group</DLAttribute> 

-<!- Parts are files stored in object servers~> 

-<!— transcript file goes into part 10— > 

<DLPart id="trspart" format="txt">10</DLPart> 

-<!-- XML image of asset data goes into part 20, and is indexed by TextMiner— > 

<DLPart id="tmpart' ' format="xml">20</DLPart> 

-<!-- Storyboard as text file, is backed up in part 30— > 

<DLPart id="sbpart" format="txt">30</DLPart> 

-<!- Tar file of .jpgs for storyboard, are backed up in part 40 ~> 

<DLPart id="tarpart" format="tar">40</DLPart> 

</DLIndexClass> 

-<DLIndexClass dlname="Icons"> 

<DLAttribute id="PIl " datatype="VarChar">Video_Category</DLAttribute> 
<DLAttribute id="PI2 " datatype=" VarChar">Video_IconFile</DLAttribute> 
</DLIndexClass> 
</DLSystem> 
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Whether XML or Java is used to store the system description 200 depends upon the 
particular needs and abilities of a user. For example, Java is a more straight forward 
language and easier for a user, whereas XML, which is a more structured language, requires 
more user knowledge and skill due to the more precise programming requirements. Further, 
5 more current systems are coded in Java than in XML and thus, documents coded in Java may 
be more compatible with current systems. However, given the recent surge of XML 
supporters, this may change in the future. XML may be preferred to Java since Java is not 
portable to other systems, and the decisions made by a Java program may have to be 
analyzed to determine how the program is being processed by Java. With XML, users are 
1 0 more able to determine how the XML document is being processed as compared to Java 

which requires more user analysis. Further, as XML is gaining popularity and is becoming a 
widely accepted way to describe the structure of documents, industry standard tools can be 
used with XML documents. Thus, whether an XML document or a Java document is used 
depends on the skill and needs of individual users and the eventual acceptance of XML. 
1 5 Those skilled in the art will recognize that other document formats besides XML and J ava 
may be used in conjunction with the code generation system 119. 

In an alternative embodiment, the data entered into the system description 200 of the 
markup language file may assume the form of a table. Rows of the table may represent each 
object to be built. Columns of the table may correspond to an attribute or association of each 
20 object identified in rows. Thus, column 1 may represent the storage location, column 2 may 
indicate that the data is linked to a different table, and so on. 

Continuing with block 310, the code generator 230 builds the structure of the custom 
database 240 based on the system description 200. The database structure 240 may include 
various objects such as tables, which provide the manner in which data is stored and 
25 retrieved. A single system description 200 statement may generate many objects. The 

objects may form one or more databases which in turn, may form a digital library 107. Thus, 
based on the statement or statements in the markup file system description 200, a single 
object may be generated, multiple objects may be generated, or a whole database of objects 
may be generated. 
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Generating objects based on system descriptions 200 as compared to programming 
numerous lines of code can save a significant amount of time. This is especially true if the 
custom database includes many objects and/or large objects. In addition, if the database is to 
be altered, the objects forming the custom database can be modified by modifying the system 
5 description 200 rather than coding new objects, receding old objects and reindexing the 
contents of the custom database after the changes are implemented. 

Further, if necessary, objects which were not created by the code generator 230 are 
manually constructed. In other words, if the code generator 230 did not generate a particular 
object based on the system description 200, then these remaining objects must be hard coded 

10 and added to the custom database structure in order to create a complete custom database or 
digital library 107. Similarly, any other object changes or deletions which were not 
implemented with the system description 200 must be hard coded. However, if the code 
generator 230 can generate all of the objects based on the markup language file 200, then 
there is no need to perform further programming to construct objects manually. 

15 Additionally, since the system description 200 describes the custom database, there 

may be more than one description that results in the same custom database. In other words, 
the system description 200 may be modified while still producing the same database structure 
240. 

In block 320, the code generator 230 may also generate a program to store data in the 
20 custom database. Data is stored and retrieved to and from the custom database based on the 
generated and any manually constructed objects. In other words, the database structure 240 
comprises objects into the desired custom database which may be, for example, a relational 
database. When objects are stored to the custom database, an index of the contents of the 
custom database may also be generated. 
25 Different system descriptions 200 may describe the same custom database, and thus, 

different system descriptions may generate the same database structure 240. In other words, 
the database structure may be transparent to changes in the system description 200 such that 
the same database structure 240 is generated with different system descriptions 200. 
In block 330, the code generator 230 generates a program to locate data in the 
30 database, such as a search engine 250. When search query is executed against the custom 
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database by a search engine program 260, the search engine program 260 may refer to the 
index created by the database program 250 when the objects were stored and retrieve the 
objects or object data requested by the query. As objects are modified or as new object are 
added or deleted by, for example, a different system description 200, then the database 

5 program 250 may store or delete these objects and index them accordingly. The search 
engine program may execute queries against the custom database using search engmes 
executed in Java, Hyper Text Markup Language (HTML) or other high level languages. In 
addition, the search engine program 260 may be a text search engine. Those skilled in the art 
will recognize that the code generator 230 may generate search engine programs 260 

1 0 executable using various language formats. 

As previously explained with respect to database structures 240, multiple system 
descriptions 200 may describe the custom database, and thus, different system descriptions 
200 may generate the same search engines 250. In other words, search engines 250 may be 
transparent to changes in the system description 200. 

1 5 Then, in block 340, the code generation system generates a user interface to access 

the custom database if a user interface is needed to enable a user to access the custom 
database structure 240 and related search engines 250. 

CONCLUSION 

This concludes the description of embodiments of the invention. The following 
20 describes some alternative embodiments for accompUshing the present invention. For 

example, any type of computer, such as a mainframe, minicomputer, or personal computer, or 
computer configuration, such as a timesharing mainframe, local area network, or standalone 
personal computer, could be used with the present invention. Additionally it will be 
understood that the object-oriented framework for providing access control can be used to 
25 provide access control to various types of multimedia datastores, and is not limited to a 

digital library 107. It will also be understood that the functions and methods described in the 
sample classes above can be varied and modified as necessary without departing from the 
present invention. 
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The foregoing description of embodiments of the present invention have been 
presented for the purposes of illustration and description. It is not intended to be exhaustive 
or to limit the invention to the precise forms disclosed. Many modifications and variations 
are possible in light of the above teaching. It is intended that the scope of the invention be 
limited not by this detailed description, but rather by the claims appended hereto. 
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